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METHOD AND SYSTEM FOR DELIVERING WIRELESS MESSAGES 
AND INFORMATION TO PERSONAL COMPUTING DEVICES 

5 

BACKGROUND OF THE INVENTION 

1 . FIELD OF THE INVENTION 

The present invention relates to wireless communications. More 
particularly, the invention relates to a method and system for automatically pushing 
10 wireless messages and other information to personal computing and communication 
devices such as personal digital assistants. 

2. DESCRIPTION OF THE PRIOR ART 

The market for wireless communication services has grown dramatically 

15 in the past few years and is expected to grow at an even faster rate in the future. Many 
experts predict that wireless communication services will soon surpass traditional "wired" 
methods of communication. Wireless communication services are no longer limited to 
voice traffic, but instead now include voice and data traffic so that all types of messages 
and information can be wirelessly transmitted to and from mobile devices. 

20 Unfortunately, current wireless communication services, as well as 

conventional wired communication services such as e-mail, voice mail, telephone 
services, etc., require users to connect to a provider by dialing-in and/or accessing a 
network before information can be retrieved. This is a problem because users often 
cannot regularly check for new messages and information and therefore often retrieve 

25 time-sensitive information too late. 

The above-described problem has been partially remedied by wireless 
communication services that automatically "push" information to users rather than 
requiring the users to "pull" the information from a provider. However, such push 
communication services still require the users to be connected to a service provider to 

30 be able to use and act upon the information. Once the users go off-network or off-line, 
the information cannot be used and/or acted upon. Moreover, existing push types of 
communication services can only push short messages and are therefore not robust 
enough for many business applications that require more extensive messages and data 
to be pushed to users. 

35 
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SUMMARY OF THE INVENTION 

The present invention solves the above-described problems and provides 
a distinct advance in the art of communication methods. More particularly, the present 
invention provides a method and system for pushing information to personal computing 
5 and communication devices operated by users in such a way that the users can use 
and/or act upon the information even when the users are off-network or off-line. The 
present invention also provides a method and system for automatically "provisioning" 
personal computing and communication devices so that the devices may be used to act 
upon the information that is pushed to the devices. 
10 One preferred embodiment of the present invention is implemented with 

O a computer network that is coupled with at least one wireless communication service 
m provider. The computer network is operated by an administrator or provider that offers 
fi push message and information delivery services in accordance with the present 
=P invention. Senders of messages and other information may access the computer 
S15 network and provide information destined for a recipient. The computer network then 
conditions the information and stores the information in a queue until a computing and 
O communication device operated by the recipient is in communication with a 
□ corresponding wireless communication service provider. The computer network then 
d automatically pushes the information to the device once it is in communication with the 
20 service provider and automatically loads the information into appropriate databases 
and/or programs in the device. The device thus receives necessary information without 
requiring the recipient to request the information or to enter or load the information into 
the appropriate program or database residing on the device. 

The computer network may also provision devices by automatically loading 
25 and assembling software applications in the devices wirelessly without input or 
configuration from users of the device. For example, in one embodiment of the 
invention, the computer network may push information to a device operated by a 
recipient as described above. The device may then determine that it does not have the 
necessary applications and/or software versions to process the information and thus 
30 automatically transmits a wireless message back to the computer network with an 
indication of what applications and/or software versions need to be sent to the device. 
The computer network then automatically pushes any additional necessary software to 
the device. This allows all information and necessary programs to be seamlessly 
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pushed to a device without requiring the user of the device to determine which programs 
are necessary to run the information, request the information, or to load the information 
and programs into the device. 

These and other important aspects of the present invention are described 
5 more fully in the detailed description below. 

BRIEF DESCRIPTION OF THE DRAWING FIGURES 

A preferred embodiment of the present invention is described in detail 

below with reference to the attached drawing figures, wherein: 
10 Fig. 1 is a schematic diagram depicting computer and communications 

equipment that may be used to implement certain aspects of the present invention. 
;jj Fig. 2 is a schematic diagram depicting certain of the components of Fig. 

^ 1 in more detail. 

La The drawing figures do not limit the present invention to the specific 

if embodiments disclosed and described herein. The drawings are not necessarily to 
-° scale, emphasis instead being placed upon clearly illustrating the principles of the 
H= invention. 

O DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 

2§ The present invention can be implemented in hardware, software, 

firmware, or a combination thereof. In a preferred embodiment, however, the invention 
is implemented with one or more computer programs that operate computer and 
communications equipment broadly referred to by the numeral 10 in Fig. 1. The 
computer and communications equipment 10 includes a computer network 12, a 

25 computer network 14, a wireless communication service provider network 16, and a 
plurality of computer and communication devices 18. The computer program and 
equipment 10 illustrated and described herein are merely examples of programs and 
equipment that may be used to implement preferred embodiments of the present 
invention and may be replaced with other software and computer equipment without 

30 departing from the scope of the present invention. 

The computer network 12 is preferably operated by an administrator or 
provider of the services of the present invention and may include a variety of different 
conventional computing equipment. In one preferred embodiment of the present 
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invention illustrated in Fig. 2, the computer network includes a server gateway computer 
20, a web server computer 22, and a communications server 24. Each of the computers 
20, 22, 24 may be any computing device such as a network computer running Windows 
NT, Novell Netware, Unix, or any other network operating system. The computers are 
5 preferably coupled to one another and to other equipment such as various databases 
26 and computers or terminals 28 by a wireless area network 30 or other conventional 
network. The web server computer 22 may also be coupled with a hub 32, a firewall 34, 
another hub 36, and a router 38. The web server computer 22 also includes 
conventional web hosting operating software, an Internet connection such as a modem, 

10 DSL converter or ISDN converter, and is assigned a URL and corresponding domain 
name so that the web server computer can be accessed via the Internet in a 

5 conventional manner. 

f jj The computer network 14 represents any number of computer systems 

W that may be operated by persons or entities wishing to send messages and other 
j(5 information to recipients and may include any types of conventional computer 

equipment. In one preferred embodiment, each computer network 14 is coupled with 
H the computer network 1 2 via a frame relay or VPN connection 40 and includes one or 
ill more server computers 42 and one or more personal computers 44 that may access the 
9 server computer 42 via a communications network 46 such as the Internet. In another 
O0 embodiment of the invention, senders of messages and other information may also 

access the web server computer 22 of the computer network 12 with one or more 

personal computers 48 via the Internet 50. 

The wireless communications network 16 represents any number of 

conventional wireless communication provider networks such as PCS, ReFLEX, 
25 Advanced Radio Data Network and cellular networks that may be used to implement 

certain steps of the present invention. Each wireless network includes various 

computing equipment broadly referred to by the numeral 52 and a plurality of broadcast 

antennas 54 that serve different cells or coverage areas. 

The computing and communication devices 18 are operated by recipients 
30 of messages and other information and preferably are handheld personal digital 

assistants such as those manufactured and sold by Palm, Handspring, RIM, Symbol, 

and Kyocera. The computing and communication devices 18 may also be personal or 

laptop computers such as those manufactured and sold by Dell, Compaq, Gateway, or 
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any other computer manufacturer; intelligent mobile phones; pagers; or even Internet 
appliances that are specifically designed for accessing the Internet. Each computing 
device 14 includes wireless communications capabilities so that it can send and receive 
wireless messages and other information. 
5 The computer programs of the present invention are stored in or on 

computer-readable medium residing on or accessible by the computer network 12 and 
the devices 18 for instructing the equipment to operate as described herein. Each 
computer program preferably comprises an ordered listing of executable instructions for 
implementing logical functions in the computer network 12 and the devices 18. The 
10 computer programs can be embodied in any computer-readable medium for use by or 
in connection with an instruction execution system, apparatus, or device, such as a 
*B computer-based system, processor-containing system, or other system that can fetch 
the instructions from the instruction execution system, apparatus, or device, and execute 
% the instructions. In the context of this application, a "computer-readable medium" can 
ill 5 be any means that can contain, store, communicate, propagate or transport the program 
,7 for use by or in connection with the instruction execution system, apparatus, or device. 
JIJ The computer-readable medium can be, for example, but not limited to, an electronic, 
hJ magnetic, optical, electro-magnetic, infrared, or semi-conductor system, apparatus, 
q device, or propagation medium. More specific, although not inclusive, examples of the 
L l>0 computer-readable medium would include the following: an electrical connection having 
one or more wires, a portable computer diskette, a random access memory (RAM), a 
read-only memory (ROM), an erasable, programmable, read-only memory (EPROM or 
Flash memory), an optical fiber, and a portable compact disk read-only memory 
(CDROM). The computer-readable medium could even be paper or another suitable 
25 medium upon which the program is printed, as the program can be electronically 
captured, via for instance, optical scanning of the paper or other medium, then compiled, 
interpreted, or otherwise processed in a suitable manner, if necessary, and then stored 
in a computer memory. 

The computer programs of the present invention preferably include 
30 communication and provisioning programs residing on the computer network 12 and 
communication and provisioning programs as well as custom application programs, form 
applications, or other interpretive programs residing on each of the devices 18. The 
functionality and operation of several preferred implementations of these programs are 
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described in more detail below. In this regard, some of the steps discussed below may 
represent a module segment or portion of code of the computer programs of the present 
invention which comprises one or more executable instructions for implementing the 
specified logical function or functions. In some alternative implementations, the 
5 functions described may occur out of the order described. For example, two functions 
described as being in succession may in fact be executed substantially concurrently, or 
the functions may sometimes be executed in the reverse order depending upon the 
functionality involved. 

In one application of the present invention, the above-described computer 
10 and communications equipment 10 and computer programs are used to automatically 
push dispatch-type information from senders to recipients, request acknowledgment 
y3 from the recipients, and then transmit task status information from the recipients back 
■C to the computer network 1 2 for delivery to the senders. The senders of the information 
•jf may include companies such as trucking companies or service companies, and the 
Rl 5 recipients may include workers of the companies such as truck operators, electricians, 
J plumbers, technicians, or computer service personnel. As used herein, the term 
II; "information" is meant to include all types of messages, data, programs, applications, 
IV and other information that senders may wish to send to recipients, or vice versa. 

A sender that wishes to push information to a recipient first accesses the 
H20 computer network 12 via one of the computer networks 14 or computers 48 and submits 
dispatch information to the computer network 1 2. The dispatch information may include, 
for example, information relating to a maintenance activity, a load pick-up, a load 
delivery, or other type of project. Such information may also include task lists, punch 
lists, parts lists, the address for a pick-up or project start point, the address for a drop-off 
25 or project stop point, a date and time for the requested pick-up or drop-off, detailed 
instructions relating to the tasks to be performed, and other related information. This 
information may be generated with an Internet-based dispatch application and may 
involve the use of a database that contains attributes for tracking status information 
related to the task (i.e. accepted, declined, arrived, finished). 
30 Once the sender submits the above dispatch information to the computer 

network 12, the computer network 12 conditions or processes the information so that it 
may be delivered to the intended recipient. The computer network 12 does so by first 
creating a unique message ID number for the information that is to be sent. The 
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computer network 12 then records the information in a recovery log using the message 
ID so that it may be later recovered. The information is then moved to a queue in the 
computer network 12 and stored based on the message type and assigned certain 
tracking information such as a process code, a format code, and a version number. 
5 The computer network 12 may at this point convert the information to 

transmittable strings in a compressed, binary, or encrypted mode. The information is 
then parsed into a series of message packets and then moved to a packet queue. The 
message packets are next sent from the packet queue to a communication thread of a 
wireless communication service provider 16 which serves the device 18 for which the 
10 information is destined. When the provider 16 acknowledges receipt of the message 
packets, the computer network 12 updates the status of the information in the recovery 
;^ log. A record for the information is then moved to a transaction log for record-keeping 
C purposes. Finally, the message packets are delivered to a queue operated by the 
J5 wireless service provider 16. 

1 Jl 5 The wireless service provider 1 6 then delivers the message packets to the 

nearest transmission tower 54 according to the last known position of the device 1 8 as 
5 listed in a home location register (HLR) or visiting location register (VLR) accessible by 
= * the provider. Once the device 18 is in range and in communication with the wireless 
C: service provider, the message packets are broadcast to the device in a conventional 
"20 manner. 

A communication layer on the device 1 8 receives and stores the message 
packets in a packet queue, turns on the device, and activates a communication program 
residing on the device 18 and configured in accordance with one aspect of the present 
invention. The communication program processes the message packets by stripping the 

25 header from each packet, concatenating the packets in sequence order, converting the 
strings of information from transmittable strings to the appropriate format for the program 
or application that will access or run the information (i.e. compressed, binary, or 
encrypted mode), and inserting the message number, message description, message 
category, and date into a message manager database. The communication program 18 

30 also runs error tests to ensure integrity of the information, and deletes the packets from 
the packet queue if the information was received error-free. The communication 
program then automatically loads the information into the appropriate program or 
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application residing on the device 18 so that the information can be acted upon by the 
user of the device 18. 

A custom dispatch application on the device 1 8 then receives the message 
string from the communication program, sounds an alert if the information is marked as 
5 urgent, and displays the dispatch information so that the user of the device 18 may 
accept, decline, or otherwise comment on the dispatch information. Once the recipient 
accepts or declines, the dispatch application composes an automatic feedback message 
that is to be transmitted to the computer network 12. The feedback message is then 
passed to the communication program residing on the device 18. 
1 0 The communication program residing on the device 1 8 then processes the 

feedback message by assigning a message key to the message (if needed), counting 
the characters in the message, and determining the number of packets required to 
; fi transmit it. Configuration parameters pertinent to the device 18, the wireless service 
s p provider 1 6, and the computer network 1 2 are stored on the device 1 8 in a configuration 
Ml 5 file to determine optimal packet sizes. The communication program then builds packet 
headers from the message number and packet sequence numbers and splits the 
]Z message into a number of packets. The packet headers are then concatenated onto the 
SU front of each packet, and the packets are moved to an outgoing queue. 
3 The communication layer on the device 18 then receives and stores the 

H20 message packets and prepares the device 1 8 to transmit the packets. The packets are 
transmitted from the device 18 to the nearest tower 54, which then confirms receipt of 
the packets. Specifically, the wireless service provider 16 receives the message 
packets, recognizes the packet identifier and/or address, acknowledges receipt, and 
moves the message packets to a corresponding queue residing in the computer network 
25 12. 

The computer network 1 2 next processes the incoming feedback message 
by creating a unique message ID number if the message does not have an existing 
message ID and then recording the message packets with the message ID in the 
recovery log. The message packets are then moved to a queue based on the message 
30 type. These packets are processed by removing packet headers and concatenating into 
a single message string in sequence order. The message string is then converted from 
transmittable characters into appropriate compressed, binary, or encrypted strings. The 
status of the message in the log is then updated. Finally, the message record is moved 
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to a transaction log for record-keeping and the message string is transmitted to a queue 
on the sender's computer equipment 14 or 48. 

The sender's computer equipment 14 or 48 receives the message from the 
computer network 12 and acknowledges acceptance. The information is then stored as 
5 a record in a task status database associated with the dispatch assignment. Dispatchers 
may then access the task status database to evaluate which tasks have been assigned, 
accepted, or declined. 

In another application of the present invention, the above-described 
computer and communications equipment 10 and computer programs are used to 
1 0 automatically provision the devices 1 8 by sending software upgrades, new applications 
or programs, or other large binary objects to the devices 18. This allows users of the 
' S C devices 18 to act upon information that is pushed to the devices 18 even if the devices 
fj 18 do not have all necessary applications and/or software. 

; p For example, in one embodiment of the invention, the computer network 

Ki5 may push information to a device operated by a recipient as described above. The 
? f device may then determine from the information what applications and/or software is 
needed to act upon the information. The device then automatically generates and 
!}: transmits a wireless message back to the computer network with an indication of what 
J5 applications and/or software are needed. The computer network then automatically 
u 20 pushes any necessary software to the device. This allows all information and necessary 
programs to be seamlessly pushed to a device without requiring the user of the device 
to determine which programs are necessary to run the information, request the 
information, or load the information and programs into the device. 

For this application, the computer network 12 includes a library that can be 
25 populated with various binary objects such as the software upgrades, applications, and 
other items discussed above. This library also preferably includes a distribution list that 
lists all recipients that have received each object, a description of each object, a final 
assembled size of each object, a check sum benchmark to confirm that each object has 
been assembled in the correct sequence, and a binary copy of each object. Attributes 
30 for tracking which recipients have acknowledged receipt of an object may also be stored 
in or alongside the library. 

An object that is to be sent to a device 18 is first passed to the gateway 
computer 20. The gateway computer 20 then conditions or processes the object so that 
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it may be more easily delivered to the intended recipient. The computer network 12 does 
so by first creating a unique message ID number for the object. The computer network 
12 then records the object in a recovery log using the message ID so that it may be later 
recovered. The object is then moved to a queue in the computer network 12 and stored 
5 based on the message type and assigned certain tracking information such as a process 
code, a format code, and a version number. 

The computer network 12 may at this point convert the object to 
transmittable strings in a compressed, binary, or encrypted mode. The object is then 
parsed into a series of message packets and then moved to a packet queue. The 
1 0 message packets are next sent from the packet queue to a communication thread of a 
^ wireless communication service provider 16 which serves the device 18 for which the 
;S object is destined. When the provider 1 6 acknowledges receipt of the message packets, 
h the computer network 12 updates the status of the information in the recovery log. A 
]% record for the object is then moved to a transaction log for record-keeping purposes, 
ffil 5 Finally, the message packets are delivered to a queue operated by the wireless service 
provider 16. 

The wireless service provider 1 6 then delivers the message packets to the 
{U nearest transmission tower 54 according to the last known position of the device 1 8 as 
p listed in an HLR or VLR. Once the device 18 is in range and in communication with the 
'"'20 wireless service provider, the message packets are broadcast to the device in a 
conventional manner. 

A communication layer on the device 18 receives and stores the message 
packets in a packet queue, turns on the device, and activates a communication program 
residing on the device 18 and configured in accordance with one aspect of the present 
25 invention. The communication program processes the message packets by stripping the 
header from each packet, concatenating the packets in sequence order, converting the 
strings of information from transmittable strings to the appropriate format for the object, 
and inserting the message number, message description, message category, and date 
into a message manager database. The communication program 18 also runs error 
30 tests to ensure integrity of the object, and deletes the packets from the packet queue if 
the object was received error-free. 

The communication program passes the assembled object to a 
provisioning program residing on the device 18. The provisioning program then loads 
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the object string from the communication program and proceeds to assemble and test 
the object based on certain header information including the check sum for the 
assembled object, the size of the assembled object, and the creator ID assigned to the 
object. Once the object has been assembled and confirmed, the provisioning program 
5 installs the object on the device and creates a feedback message indicating that the 
installation has been successful. The feedback message is then transferred to the 
communication program residing on the device 18. 

The communication program processes the feedback message by 
assigning a message key to the message (if needed), counting the characters in the 
1 0 message, and determining the number of packets required to transmit it. Configuration 
^ parameters pertinent to the device 18, the wireless service provider 16, and the 
:5 computer network 12 are stored on the device 18 in a configuration file to determine 
CI optimal packet sizes. The communication program then builds packet headers from the 
J message number and packet sequence numbers and splits the message into a number 
®1 5 of packets. The packet headers are then concatenated onto the front of each packet, 

and the packets are moved to an outgoing queue. 
J-i The communication layer then receives and stores the message packets 

and prepares the device 1 8 to transmit the packets. The packets are transmitted from 
□ the device 18 to the nearest tower 54, which then confirms receipt of the packets. 
f ~' 20 Specifically, the wireless service provider 1 6 receives the message packets, recognizes 
the packet identifier and/or address, acknowledges receipt, and moves the message 
packets to a corresponding queue residing in the computer network 12. 

The computer network 1 2 next processes the incoming feedback message 
by creating a unique message ID number if the message does not have an existing 
25 message ID and then recording the message packets with the message ID in the 
recovery log. The message packets are then moved to a queue based on the message 
type and then concatenated into a single message string. The message string is then 
converted from transmittable characters into appropriate compressed, binary, or 
encrypted strings. The status of the message in the log is then updated. Finally, the 
30 message record is moved to a transaction log for record-keeping and the message string 
is transmitted to a queue on the sender's computer equipment 14 or 48. 

The sender's computer equipment 14 or 48 receives the message from the 
computer network 12 and acknowledges receipt. Administrators may then access the 



-12- 

computer network 12 and see which recipients have received a new object by viewing 
web pages that access records in the computer network 12. 

In another application of the present invention, the above-described 
computer and communications equipment 10 and computer programs may be used to 
5 automatically push calendar information to the devices 18. The calendar information 
may include, for example, meeting dates, travel schedules, deadlines, etc. 

A sender that wishes to push such calendar information to a recipient first 
accesses the computer network 12 via one of the computer networks 14 or computers 
48 and submits the information to the computer network 12. The computer network 12 
1 0 then conditions or processes the information so that it may be delivered to the intended 
recipient. The computer network 12 does so by first creating a unique message ID 
2 number for the information. The computer network 12 then records the information in 
*Q a recovery log using the message ID so that it may be later recovered. The information 
J is then moved to a queue in the computer network 1 2 and stored based on the message 
f 2l5 type and assigned certain tracking information such as a process code, a format code, 
and a version number. 

)«5 The computer network 12 may at this point convert the information to 

2f transmittable strings in a compressed, binary, or encrypted mode. The information is 
P then parsed into a series of message packets and then moved to a packet queue. The 
^'20 message packets are next sent from the packet queue to a communication thread of a 
wireless communication service provider 16 which serves the device 18 for which the 
information is destined. When the provider 16 acknowledges receipt of the message 
packets, the computer network 12 updates the status of the information in the recovery 
log. A record for the information is then moved to a transaction log for record-keeping 
25 purposes. Finally, the message packets are delivered to a queue operated by the 
wireless service provider 16. 

The wireless service provider 1 6 then delivers the message packets to the 
nearest transmission tower 54 according to the last known position of the device 18 as 
listed in an HLR or VLR. Once the device 18 is in range and in communication with the 
30 wireless service provider, the message packets are broadcast to the device in a 
conventional manner. 

A communication layer on the device 1 8 receives and stores the message 
packets in a packet queue, turns on the device, and activates a communication program 
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residing on the device 18 and configured in accordance with one aspect of the present 
invention. The communication program processes the message packets by stripping the 
header from each packet, concatenating the packets in sequence order, converting the 
strings of information from transmittable strings to the appropriate format for the program 
5 or application that will access or run the information (i.e. compressed, binary, or 
encrypted mode), and inserting the message number, message description, message 
category, and date into a message manager database. The communication program 18 
also runs error tests to ensure integrity of the information, and deletes the packets from 
the packet queue if the information was received error-free. The communication 
10 program then automatically loads the information into the appropriate program or 
application residing on the device 18 so that the information can be acted upon by the 
;g user of the device 1 8. 

•S A custom calender or scheduling application on the device 18 then 

]S receives the message string from the communication program, sounds an alert if the 
51 5 information is marked as urgent, and displays the information so that the user of the 
device 1 8 may act upon it. The user may, for example, review proposed meeting dates 
EJ and times and either accept or decline the proposed times or press a button labeled 
^ "Later." Pressing the Later button causes the display screen to delay requesting this 
O information until the next time the device is turned on. If the recipient accepts or 
^20 declines, the calender application adds the event to a scheduling program and 
composes an automatic feedback message that is to be transmitted to the computer 
network 12. The feedback message is then passed to the communication program 
residing on the device 18. 

The communication program residing on the device 1 8 then processes the 
25 feedback message by assigning a message key to the message (if needed), counting 
the characters in the message, and determining the number of packets required to 
transmit it. Configuration parameters pertinent to the device 18, the wireless service 
provider 16, and the computer network 12 are stored on the device 18 in a configuration 
file to determine optimal packet sizes. The communication program then builds packet 
30 headers from the message number and packet sequence numbers and splits the 
message into a number of packets. The packet headers are then concatenated onto the 
front of each packet, and the packets are moved to an outgoing queue. 
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The communication layer on the device 18 then receives and stores the 
message packets and prepares the device 1 8 to transmit the packets. The packets are 
transmitted from the device 18 to the nearest tower 54, which then confirms receipt of 
the packets. Specifically, the wireless service provider 16 receives the message 
5 packets, recognizes the packet identifier and/or address, acknowledges receipt, and 
moves the message packets to a corresponding queue residing in the computer network 
12. 

The computer network 1 2 next processes the incoming feedback message 
by creating a unique message ID number if the message does not have an existing 
10 message ID and then recording the message packets with the message ID in the 
recovery log. The message packets are then moved to a queue based on the message 
m type and then concatenated into a single message string. The message string is then 
converted from transmittable characters into appropriate compressed, binary, or 
W encrypted strings. The status of the message in the log is then updated. Finally, the 
Ml 5 message record is moved to a transaction log for record-keeping and the message string 
is transmitted to a queue on the sender's computer equipment 14 or 48. 

A scheduling program on the sender's computer equipment 14 or 48 
111 receives the message from the computer network 1 2 and acknowledges acceptance of 
S the proposed meeting or other event. The information is then stored as a record in a 
Q20 calendering database. Administrators can then access the calendering database to see 
which recipients have accepted the proposed meeting date. 

In another application of the present invention, the above-described 
computer and communications equipment 10 and computer programs may be used to 
automatically send to one or more of the devices 18 a request for data matching a 
25 particular criteria. The device then fills the request and sends the results back to the 
computer network 12 for delivery to the requestor of the data. 

A sender that wishes to request such a data search first accesses the 
computer network 12 via one of the computer networks 14 or computers 48 and 
identifies the search criteria and the devices to be searched. The search criteria may 
30 be generated with any known data search program or application. 

Once the sender submits the above search information to the computer 
network 12, the computer network 12 conditions or processes the information so that it 
may be delivered to the intended recipient. The computer network 12 does so by first 



-15- 



creating a unique message ID number for the information that is to be sent. The 
computer network 12 then records the information in a recovery log using the message 
ID so that it may be later recovered. The information is then moved to a queue in the 
computer network 12 and stored based on the message type and assigned certain 
5 tracking information such as a process code, a format code, and a version number. 

The computer network 12 may at this point convert the information to 
transmittable strings in a compressed, binary, or encrypted mode. The information is 
then parsed into a series of message packets and then moved to a packet queue. The 
message packets are next sent from the packet queue to a communication thread of a 
10 wireless communication service provider 16 which serves the device 18 for which the 
information is destined. When the provider 16 acknowledges receipt of the message 
|? packets, the computer network 12 updates the status of the information in the recovery 
=p log. A record for the information is then moved to a transaction log for record-keeping 
^i; purposes. Finally, the message packets are delivered to a queue operated by the 
0515 wireless service provider 16. 

r The wireless service provider 1 6 then delivers the message packets to the 

nearest transmission tower 54 according to the last known position of the device 18 as 

W listed in an HLR or VLR. Once the device 18 is in range and in communication with the 

5 wireless service provider, the message packets are broadcast to the device in a 

u 20 conventional manner. 

A communication layer on the device 18 receives and stores the message 
packets in a packet queue, turns on the device, and activates a communication program 
residing on the device 18 and configured in accordance with one aspect of the present 
invention. The communication program processes the message packets by stripping the 
25 header from each packet, concatenating the packets in sequence order, converting the 
strings of information from transmittable strings to the appropriate format for the program 
or application that will access or run the information (i.e. compressed, binary, or 
encrypted mode), and inserting the message number, message description, message 
category, and date into a message manager database. The communication program 18 
30 also runs error tests to ensure integrity of the information, and deletes the packets from 
the packet queue if the information was received error-free. The communication 
program then automatically loads the information into a custom search application 



-16- 

residing on the device 18 so that the information can be acted upon by the user of the 
device 18. 

The custom search application on the device 18 then receives the 
message string from the communication program and initiates a series of find operations 
5 on the device to locate all records matching the search criteria. Once the records have 
been identified, the results are collected and formatted to be transmitted to the computer 
network 1 2. The results are then passed to the communication program residing on the 
device 18. 

The communication program then processes the results by assigning a 
1 0 message key to the message (if needed), counting the characters in the message, and 
r , determining the number of packets required to transmit it. Configuration parameters 
:~ pertinent to the device 18, the wireless service provider 16, and the computer network 
J3 12 are stored on the device 18 in a configuration file to determine optimal packet sizes. 
3 The communication program then builds packet headers from the message number and 
■J1 5 packet sequence numbers and splits the message into a number of packets. The packet 
headers are then concatenated onto the front of each packet, and the packets are 
moved to an outgoing queue. 
^ The communication layer on the device 18 then receives and stores the 

3 message packets and prepares the device 18 to transmit the packets. The packets are 
^ 20 transmitted from the device 18 to the nearest tower 54, which then confirms receipt of 
the packets. Specifically, the wireless service provider 16 receives the message 
packets, recognizes the packet identifier and/or address, acknowledges receipt, and 
moves the message packets to a corresponding queue residing in the computer network 
12. 

25 The computer network 1 2 next processes the incoming results by creating 

a unique message ID number if the message does not have an existing message ID and 
then recording the message packets with the message ID in the recovery log. The 
message packets are then moved to a queue based on the message type and then 
concatenated into a single message string. The message string is then converted from 

30 transmittable characters into appropriate compressed, binary, or encrypted strings. The 
status of the message in the log is then updated. Finally, the message record is moved 
to a transaction log for record-keeping and the message string is transmitted to a queue 
on the sender's computer equipment 14 or 48. 
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The sender's computer equipment 14 or 48 receives the results from the 
computer network 12 and acknowledges acceptance. An information requestor may 
then access the results to determine what records or data were found that meet the 
criteria. Alternatively, the above-described data search can be initiated by one of the 
5 devices 18 and the results can be sent to the requesting device. 

In another application of the present invention, the above-described 
computer and communications equipment 10 and computer programs may be used to 
automatically request location information from multiples devices 18 and determine 
which device 18 is closest to a particular location. Such information may be used for 
10 dispatching mobile units to assignments based on location information for the mobile 
units. 

5 A sender that wishes to push location information to a recipient first 
ffj accesses the computer network 1 2 via one of the computer networks 14 or computers 
Q 48 and submits such information to the computer network 1 2. The location information 
j5 may be generated with any known dispatch application and may also include project 

information such as an address for a project and a scheduled date and time. The 
u location information requested from the devices 18 is preferably GPS location 
Jj; coordinates generated from GPS receivers located on the devices 18. 
Q Once the sender submits the above location information to the computer 

6 network 1 2, the computer network 1 2 conditions or processes the information so that it 
may be delivered to the intended recipient. The computer network 12 does so by first 
creating a unique message ID number for the information that is to be sent. The 
computer network 12 then records the information in a recovery log using the message 
ID so that it may be later recovered. The information is then moved to a queue in the 

25 computer network 12 and stored based on the message type and assigned certain 
tracking information such as a process code, a format code, and a version number. 

The computer network 12 may at this point convert the information to 
transmittable strings in a compressed, binary, or encrypted mode. The information is 
then parsed into a series of message packets and then moved to a packet queue. The 

30 message packets are next sent from the packet queue to a communication thread of a 
wireless communication service provider 16 which serves the device 18 for which the 
information is destined. When the provider 16 acknowledges receipt of the message 
packets, the computer network 12 updates the status of the information in the recovery 
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log. A record for the information is then moved to a transaction log for record-keeping 

purposes. Finally, the message packets are delivered to a queue operated by the 

wireless service provider 16. 

The wireless service provider 1 6 then delivers the message packets to the 
5 nearest transmission tower 54 according to the last known position of the device 1 8 as 

listed in an HLR or VLR. Once the device 18 is in range and in communication with the 

wireless service provider, the message packets are broadcast to the device in a 

conventional manner. 

A communication layer on the device 1 8 receives and stores the message 
1 0 packets in a packet queue, turns on the device, and activates a communication program 

residing on the device 18 and configured in accordance with one aspect of the present 
S invention. The communication program processes the message packets by stripping the 
ff 1 header from each packet, concatenating the packets in sequence order, converting the 
Q strings of information from transmittable strings to the appropriate format for the program 
;te or application that will access or run the information (i.e. compressed, binary, or 

encrypted mode), and inserting the message number, message description, message 
U category, and date into a message manager database. The communication program 18 

also runs error tests to ensure integrity of the information, and deletes the packets from 
O the packet queue if the information was received error-free. The communication 
SO program then automatically loads the information into the appropriate program or 

application residing on the device 18 so that the information can be acted upon by the 

device 18. 

A custom location application on the device 1 8 then receives the message 
string from the communication program. The location application then polls a GPS 

25 receiver on or coupled with the device 1 8 through a location communication port. The 
GPS receiver provides response by providing GPS coordinate readings. The location 
application formats the GPS coordinates into an automatic feedback message to be sent 
back to the computer network 12. The feedback message is then passed to the 
communication program residing on the device 18. 

30 The communication program residing on the device 1 8 then processes the 

feedback message by assigning a message key to the message (if needed), counting 
the characters in the message, and determining the number of packets required to 
transmit it. Configuration parameters pertinent to the device 18, the wireless service 
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provider 16, and the computer network 1 2 are stored on the device 1 8 in a configuration 
file to determine optimal packet sizes. The communication program then builds packet 
headers from the message number and packet sequence numbers and splits the 
message into a number of packets. The packet headers are then concatenated onto the 
5 front of each packet, and the packets are moved to an outgoing queue. 

The communication layer on the device 18 then receives and stores the 
message packets and prepares the device 1 8 to transmit the packets. The packets are 
transmitted from the device 18 to the nearest tower 54, which then confirms receipt of 
the packets. Specifically, the wireless service provider 16 receives the message 
10 packets, recognizes the packet identifier and/or address, acknowledges receipt, and 

0 moves the message packets to a corresponding queue residing in the computer network 

1 12. 

The computer network 1 2 next processes the incoming feedback message 
S by creating a unique message ID number if the message does not have an existing 
'JS15 message ID and then recording the message packets with the message ID in the 

recovery log. The message packets are then moved to a queue based on the message 
O tyP e an d then concatenated into a single message string. The message string is then 
[if converted from transmittable characters into appropriate compressed, binary, or 
3 encrypted strings. The status of the message in the log is then updated. Finally, the 
" 20 message record is moved to a transaction log for record-keeping and the message string 

is transmitted to a queue on the sender's computer equipment 14 or 48. 

The sender's computer equipment 14 or 48 receives the message from the 

computer network 12 and acknowledges acceptance. A proximity application on the 

sender's computer equipment 14 or 48 then reviews all the responses from multiple 
25 devices 18 and estimates the distance that each device is from the target location. The 

nearest device 18 can then be dispatched as described in the dispatch application 

above. 

Although the invention has been described with reference to the preferred 
embodiment illustrated in the attached drawing figures, it is noted that equivalents may 
30 be employed and substitutions made herein without departing from the scope of the 
invention as recited in the claims. 

Having thus described the preferred embodiment of the invention, what is 
claimed as new and desired to be protected by Letters Patent includes the following: 
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CLAIMS: 

1 . A method of wirelessly delivering information comprising the steps of: 
receiving information from a sender that is destined for a recipient; 
conditioning the information so that it can be more easily delivered to the 
5 recipient; 

storing the information in a queue until a computing and communication device 
operated by the recipient is in communication with a wireless 
communication service provider; and 
provisioning the computing and communication device by pushing the information 
10 as well as all applications needed to act upon the information to the 

computing and communication device when the computing and 
;i? communication device is in communication with the wireless 

communication service provider so that the recipient may continue to use 
: C the information even when the computing and communication device is no 

1 5 longer in communication with the wireless communication service provider. 

h 2. The method as set forth in claim 1, the provisioning step further 

!4 including the steps of: 

O receiving from the computing and communication device an indication of what 

" : ~ 20 applications are needed to act upon the information; and 

pushing to the computer and communication device the applications. 



3. The method as set forth in claim 1, the information including at least 
one of the following: dispatch information, calender information, search request, location 

25 information software, and software upgrades. 

4. The method as set forth in claim 1 , the computing and communication 
device including one of the following: a personal digital assistant, a personal computer, 
a laptop computer, and an intelligent wireless phone. 

30 



5. The method as set forth in claim 1 , wherein the sender is a company 
wishing to deliver information to employees, suppliers, or customers. 
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6. The method as set forth in claim 5, wherein the recipient is an 
employee, supplier or customer of the company. 

7. The method as set forth in claim 1, the provisioning step further 
including the step of automatically loading the information into appropriate software 
applications on the computing and communication device. 

8. The method as set forth in claim 1 , the conditioning step including the 

steps of: 

creating a unique ID number for the information; 

converting the information to transmittable strings of data; and 

parsing the information into a series of message packets. 

9. A computer system for wirelessly delivering information, the system 
being operable to: 

receive information from a sender that is destined for a recipient; 

condition the information so that it can be more easily delivered to the recipient; 

store the information in a queue until a computing and communication device 
operated by the recipient is in communication with a wireless 
communication service provider; and 

provision the computing and communication device by pushing the information 
as well as all applications needed to act upon the information to the 
computing and communication device when the computing and 
communication device is in communication with the wireless 
communication service provider so that the recipient may continue to use 
the information even when the computing and communication device is no 
longerin communication with the wireless communication service provider. 

10. The system as set forth in claim 9, the system being further operable 

to: 

receive from the computing and communication device an indication of what 

applications are needed to act upon the information; and 
push to the computer and communication device the applications. 
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1 1 . The system as set forth in claim 9, the information including at least 
one of the following: dispatch information, calender information, search request, location 
information software, and software upgrades. 

5 12. The system as set forth in claim 9, the computing and communication 

device including one of the following: a personal digital assistant, a personal computer, 
a laptop computer, and an intelligent wireless phone. 

13. The system as set forth in claim 9, wherein the sender is a company 
10 wishing to deliver information to employees, suppliers, or customers. 

;S 14. The system as set forth in claim 13, wherein the recipient is an 

Ji! employee, supplier or customer of the company. 

0 5 15. The system as set forth in claim 9, the system being further operable 

' M to automatically load the information into appropriate software applications on the 

if computing and communication device. 

1 6. The system as set forth in claim 9, the system being further operable 

O20 to: 

create a unique ID number for the information; 

convert the information to transmittable strings of data; and 

parse the information into a series of message packets. 



25 
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ABSTRACT OF THE DISCLOSURE 
A method and system for pushing information to personal computing and 
communication devices operated by users in such a way that the users can use and/or 
act upon the information even when the users are off-network or off-line. The method 
and system also automatically "provisions" the personal computing and communication 
devices so that the devices may be used to act upon the information that is pushed to 
the devices. 
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